{% extends 'web/layout/basic.html' %}
{% load static %}

{% block title %}
    短信登录
{% endblock %}

{% block css %}
    <link rel="stylesheet" href="{% static 'web/css/account.css' %}">
{% endblock %}

{% block content %}
    <div class="account">
        <div class="title">用户短信登录</div>
        <form id="smsLoginForm" method="POST" novalidate>
            {% csrf_token %}
            {% for field in form %}
                {% if field.name == 'code' %}
                    <div class="form-group">
                        <label for="{{ field.id_for_label }}">{{ field.label }}</label>
                        <div class="row">
                            <div class="col-xs-7">
                                {{ field }}
                                <span class="error-msg"></span>
                            </div>
                            <div class="col-xs-5">
                                <input id="btnSms" type="button" class="btn btn-outline-secondary" value="获取验证码">
                            </div>
                        </div>
                        <div class="clearfix">
                        </div>
                    </div>
                {% else %}
                    <div class="form-group">
                        <label for="{{ field.id_for_label }}">{{ field.label }}</label>
                        {{ field }}
                        <span class="error-msg"></span>
                    </div>
                {% endif %}
            {% endfor %}
            <div>
                <div style="float: right;">
                    <a href="{% url 'login' %}">账号密码登录</a>
                </div>
            </div>
            <div class="row">
                <div class="col-xs-3">
                    <input id="btnLogin" type="button" class="btn btn-primary" value="登&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;录">
                </div>
            </div>
        </form>

    </div>
{% endblock %}

{% block js %}
    <script>
        // 页面框架加载完成后自动执行函数
        $(function () {
            bindClickBtnSMS();
            bindClickLogin();
        });

        /*
        * 点击获取验证码的绑定事件
        * */
        function bindClickBtnSMS() {
            $('#btnSms').click(function () {
                // 将所有错误信息清空
                $('.error-msg').empty();
                // 获取用户输入的手机号
                var mobile_phone = $('#id_mobile_phone').val();
                // ajax 向后台请求
                $.ajax({
                    url: "{% url 'send_sms' %}",
                    // url: '/send/sms/'
                    type: "GET",
                    data: {mobile_phone: mobile_phone, tpl: "login"},
                    dataType: 'JSON',   // 将服务器返回的数据反序列化为字典
                    success: function (res) {
                        // ajax请求发送成功之后，自动执行的函数； res是后端返回值
                        console.log("res: ", res);
                        if (res.status) {
                            sendSmsRemind();
                        } else {
                            console.log(res);
                            $.each(res.error, function (key, value) {
                                $('#id_' + key).next().text(value[0]);
                            });
                        }
                    },
                    error: function (res) {
                        console.log("error-res: ", res);
                    }
                });
            });
        }

        /*
        * 倒计时
        * */
        function sendSmsRemind() {
            var $smsBtn = $('#btnSms');
            $smsBtn.prop('disabled', true); // 禁用按钮

            var time = 60;
            var obj = setInterval(function () {
                $smsBtn.val(time + '秒后重新发送');
                time = time - 1;
                if (time < 1) {
                    clearInterval(obj);
                    $smsBtn.val('点击获取验证码').prop('disabled', false);
                }
            }, 1000);
        }

        /*
        * 点击提交（登录）
        * */
        function bindClickLogin() {
            $('#btnLogin').click(function () {
                $('.error-msg').empty();
                // 收集表单中的数据
                var form_data = $('#smsLoginForm').serialize(); // 包含所有字段数据 + csrf_token
                // 数据通过 ajax 发送到后台
                $.ajax({
                    url: '{% url 'login_sms' %}',
                    type: 'POST',
                    data: form_data,
                    dataType: 'JSON',
                    success: function (res) {
                        console.log(res);
                        if (res.status) {
                            location.href = res.data;
                        } else {
                            $.each(res.error, function (key, value) {
                                $('#id_' + key).next().text(value[0])
                            });
                        }
                    }
                });
            });
        }
    </script>
{% endblock %}